<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>插槽 - 多具名</title>
    <script src="https://unpkg.com/vue@next"></script>
  </head>
  <body>
    <div id="Application">
      <!--
        <my-container>
          <template v-slot:header>
            <h1>这里是头部元素</h1>
          </template>
          <template v-slot:main>
            <p>内容部分</p>
            <p>内容部分</p>
          </template>
          <template v-slot:footer>
            <p>这里是尾部元素</p>
          </template>
        </my-container>
        -->
        <!-- # 替代 v-slot  -->
        <my-container>
          <template #header>
            <h1>这里是头部元素</h1>
          </template>
          <template #main>
            <p>内容部分</p>
            <p>内容部分</p>
          </template>
          <template #footer>
            <p>这里是尾部元素</p>
          </template>
        </my-container>
    </div>
  </body>

  <script>
    const App= Vue.createApp({})
    const conationerComponent = {
        template:`<div>
                <slot name="header"></slot>
                <hr/>
                <slot name="main"></slot>
                <hr/>
                <slot name="footer"></slot>
            </div>`
    }
    App.component("my-container", conationerComponent);
    App.mount("#Application")
  </script>

</html>